* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    font-family: 'Poppins', sans-serif;
}

:root {
    --blue: #37a6ff;
    --white: #fff;
    --red: #f7226a;
    --bg: #04202e;
}

body {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: var(--bg);
}

#toggle {
    width: 50px;
    height: 50px;
    /*cursor CSS 属性设置鼠标光标的类型（如果有），以在鼠标指针悬停在元素上时显示*/
    cursor: pointer;
    display: flex;
    justify-content: center;
    align-items: center;
    background: var(--blue);
    transition-duration: 0.2s;
}

#toggle.active {
    background: var(--red);
}

#toggle::before {
    content: '';
    position: absolute;
    width: 30px;
    height: 2px;
    background: var(--white);
    transition-duration: 0.2s;
    transform: translateY(-10px);
    /*box-shadow CSS 属性在元素的框架周围添加阴影效果。 您可以设置多个以逗号分隔的效果。
    框阴影由相对于元素的 X 和 Y 偏移、模糊和扩散半径以及颜色来描述。 */
    box-shadow: 0 10px 0 var(--white);
}

#toggle.active::before {
    transform: translateY(0px) rotate(45deg);
    box-shadow: 0 0 0 var(--white);
}

#toggle::after {
    content: '';
    position: absolute;
    width: 30px;
    height: 2px;
    background: var(--white);
    transition-duration: 0.2s;
    transform: translateY(10px);
}

#toggle.active::after {
    transform: translateY(0px) rotate(-45deg);
    box-shadow: 0 0 0 var(--white);
}

